﻿//==================================================================
// Copyright (C) 2011 深圳市中旭企业管理股份有限公司
// 文件名: hrEmployeeTrainings.cs
// 作 者：代码自动生成
// 日 期：2012-08-15 11:08:36
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.EHR.Library
{
    /// <summary>
    /// 员工培训经历
    /// </summary>
    [Serializable]
    [Table(Name = "hrEmployeeTrainings")]
    [ZX.DBModule.Table("hrEmployeeTrainings", "ID")]
    public class hrEmployeeTrainings : ZX.DBModule.BaseEntity
    {

        #region Business Methods 业务方法

        /// <summary>
        /// 编号
        /// </summary>
        private static PropertyInfo<Guid> IDProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<Guid>("ID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid ID
        {
            get { return GetProperty(IDProperty); }
            set { SetProperty(IDProperty, value); }
        }

        /// <summary>
        /// 员工编号
        /// </summary>
        private static PropertyInfo<Guid> EmployeeIDProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<Guid>("EmployeeID"));
        [Column]
        public Guid EmployeeID
        {
            get { return GetProperty(EmployeeIDProperty); }
            set { SetProperty(EmployeeIDProperty, value); }
        }
        /// <summary>
        /// ST培训地址
        /// </summary>
        private static PropertyInfo<string> TrainingAddressProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TrainingAddress"));
        [Column]
        public string TrainingAddress
        {
            get { return GetProperty(TrainingAddressProperty); }
            set { SetProperty(TrainingAddressProperty, value); }
        }
        /// <summary>
        /// DT开始时间
        /// </summary>
        private static PropertyInfo<DateTime> BeginDateProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<DateTime>("BeginDate"));
        [Column]
        public DateTime BeginDate
        {
            get { return GetProperty(BeginDateProperty); }
            set { SetProperty(BeginDateProperty, value); }
        }
        /// <summary>
        /// DT结束时间
        /// </summary>
        private static PropertyInfo<DateTime> EndDateProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<DateTime>("EndDate"));
        [Column]
        public DateTime EndDate
        {
            get { return GetProperty(EndDateProperty); }
            set { SetProperty(EndDateProperty, value); }
        }
        /// <summary>
        /// ST培训机构
        /// </summary>
        private static PropertyInfo<string> TraniningOrganizationProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TraniningOrganization"));
        [Column]
        public string TraniningOrganization
        {
            get { return GetProperty(TraniningOrganizationProperty); }
            set { SetProperty(TraniningOrganizationProperty, value); }
        }
        /// <summary>
        /// MT培训课程
        /// </summary>
        private static PropertyInfo<string> TraniningCourseProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TraniningCourse"));
        [Column]
        public string TraniningCourse
        {
            get { return GetProperty(TraniningCourseProperty); }
            set { SetProperty(TraniningCourseProperty, value); }
        }
        /// <summary>
        /// ST证书
        /// </summary>
        private static PropertyInfo<string> CertificateProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("Certificate"));
        [Column]
        public string Certificate
        {
            get { return GetProperty(CertificateProperty); }
            set { SetProperty(CertificateProperty, value); }
        }
        /// <summary>
        /// MT培训收获
        /// </summary>
        private static PropertyInfo<string> SummarizeProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("Summarize"));
        [Column]
        public string Summarize
        {
            get { return GetProperty(SummarizeProperty); }
            set { SetProperty(SummarizeProperty, value); }
        }
        /// <summary>
        /// 改进措施
        /// </summary>
        private static PropertyInfo<string> ImprovementsProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("Improvements"));
        [Column]
        public string Improvements
        {
            get { return GetProperty(ImprovementsProperty); }
            set { SetProperty(ImprovementsProperty, value); }
        }
        /// <summary>
        /// 培训形式
        /// </summary>
        private static PropertyInfo<string> TrainningModusProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TrainningModus"));
        [Column]
        public string TrainningModus
        {
            get { return GetProperty(TrainningModusProperty); }
            set { SetProperty(TrainningModusProperty, value); }
        }
        /// <summary>
        /// 培训费用
        /// </summary>
        private static PropertyInfo<string> TrainningFeeProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TrainningFee"));
        [Column]
        public string TrainningFee
        {
            get { return GetProperty(TrainningFeeProperty); }
            set { SetProperty(TrainningFeeProperty, value); }
        }
        /// <summary>
        /// 培训老师
        /// </summary>
        private static PropertyInfo<string> TrainningTeahcherProperty = RegisterProperty(typeof(hrEmployeeTrainings), new PropertyInfo<string>("TrainningTeahcher"));
        [Column]
        public string TrainningTeahcher
        {
            get { return GetProperty(TrainningTeahcherProperty); }
            set { SetProperty(TrainningTeahcherProperty, value); }
        }

        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "TrainingAddress");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TrainingAddress", 24));
            ValidationRules.AddRule(CommonRules.StringRequired, "TraniningOrganization");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TraniningOrganization", 36));
            ValidationRules.AddRule(CommonRules.StringRequired, "TraniningCourse");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TraniningCourse", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "Certificate");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Certificate", 24));
            ValidationRules.AddRule(CommonRules.StringRequired, "Summarize");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Summarize", 300));
            ValidationRules.AddRule(CommonRules.StringRequired, "Improvements");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Improvements", 300));
            ValidationRules.AddRule(CommonRules.StringRequired, "TrainningModus");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TrainningModus", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "TrainningFee");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TrainningFee", 50));
            ValidationRules.AddRule(CommonRules.StringRequired, "TrainningTeahcher");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("TrainningTeahcher", 50));
            //base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public hrEmployeeTrainings() { }

        public static hrEmployeeTrainings New()
        {
            return DataPortal.Create<hrEmployeeTrainings>();
        }
        public static hrEmployeeTrainings Get(Guid ID)
        {
            return DataPortal.Fetch<hrEmployeeTrainings>(new SingleLazyCriteria<hrEmployeeTrainings, Guid>(ID, false));
        }
        public static void Delete(Guid ID)
        {
            DataPortal.Delete(ID);
        }

        //public override hrEmployeeTrainings Save()
        //{
        //return base.Save();
        //}
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid ID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("ID").Equal(ID);
                var data = db.Select<hrEmployeeTrainings>(q)[0];
                LoadProperty(IDProperty, data.ID);
                LoadProperty(EmployeeIDProperty, data.EmployeeID);
                LoadProperty(TrainingAddressProperty, data.TrainingAddress);
                LoadProperty(BeginDateProperty, data.BeginDate);
                LoadProperty(EndDateProperty, data.EndDate);
                LoadProperty(TraniningOrganizationProperty, data.TraniningOrganization);
                LoadProperty(TraniningCourseProperty, data.TraniningCourse);
                LoadProperty(CertificateProperty, data.Certificate);
                LoadProperty(SummarizeProperty, data.Summarize);
                LoadProperty(ImprovementsProperty, data.Improvements);
                LoadProperty(TrainningModusProperty, data.TrainningModus);
                LoadProperty(TrainningFeeProperty, data.TrainningFee);
                LoadProperty(TrainningTeahcherProperty, data.TrainningTeahcher);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(IDProperty);
        }
        #endregion

    }
}